package com.qr.service.wmyh.impl;

import java.util.List;
import java.util.Map;
import com.baomidou.mybatisplus.core.conditions.Wrapper;
import com.baomidou.mybatisplus.core.conditions.query.QueryWrapper;
import com.baomidou.mybatisplus.core.metadata.IPage;
import org.apache.ibatis.mapping.ResultMapping;
import org.springframework.beans.factory.annotation.Autowired;
import org.springframework.stereotype.Service;
import cn.krui.helper.db.DBHelper;
import cn.krui.helper.db.DataPage;
import com.qr.bean.wmyh.JbrUserScoreList;
import com.qr.bean.wmyh.JbrUserScoreListView;
import com.qr.controller.WmyhBase;
import com.qr.mapper.wmyh.JbrUserScoreListMapper;
import com.qr.mapper.wmyh.JbrUserScoreListMapperView;
import com.qr.service.wmyh.JbrUserScoreListService;
//import org.apache.dubbo.config.annotation.Service;

/**
 * @author: zc
 * email: zc8023zs@163.com
 * create_time: 2020/8/11 13:03:41
 */
@Service
//@Service(version = "1.0.0",group="dubbo")
public class JbrUserScoreListServiceImpl implements JbrUserScoreListService{
    @Autowired
    private JbrUserScoreListMapper jbrUserScoreListMapper;

    @Autowired
    private JbrUserScoreListMapperView jbrUserScoreListMapperView;
    
    @Autowired
    private DBHelper dbHelper;

    /**
     * 构造查询条件
     */
    private QueryWrapper<JbrUserScoreList> InitWrapper(JbrUserScoreList where){
        QueryWrapper<JbrUserScoreList> whereWrapper = new QueryWrapper<JbrUserScoreList>();
        if(where.getId()!=null){
			whereWrapper.eq("id",where.getId());
		}
        if(where.getUser_id()!=null){
			whereWrapper.eq("user_id",where.getUser_id());
		}
        if(where.getScore_type()!=null){
			whereWrapper.eq("score_type",where.getScore_type());
		}
        if(where.getScore()!=null){
			whereWrapper.eq("score",where.getScore());
		}
        if(where.getScore_desc()!=null){
			whereWrapper.eq("score_desc",where.getScore_desc());
		}
        if(where.getAdd_time()!=null){
			whereWrapper.eq("add_time",where.getAdd_time());
		}
        if(where.getOrder_id()!=null){
			whereWrapper.eq("order_id",where.getOrder_id());
		}
        if(where.getTraded_score()!=null){
			whereWrapper.eq("traded_score",where.getTraded_score());
		}
        return whereWrapper;
    }

    private QueryWrapper<JbrUserScoreListView> InitWrapperView(JbrUserScoreListView where){
        QueryWrapper<JbrUserScoreListView> whereWrapper = new QueryWrapper<JbrUserScoreListView>();
        if(where.getId()!=null){
			whereWrapper.eq("id",where.getId());
		}
        if(where.getUser_id()!=null){
			whereWrapper.eq("user_id",where.getUser_id());
		}
        if(where.getScore_type()!=null){
			whereWrapper.eq("score_type",where.getScore_type());
		}
        if(where.getScore()!=null){
			whereWrapper.eq("score",where.getScore());
		}
        if(where.getScore_desc()!=null){
			whereWrapper.eq("score_desc",where.getScore_desc());
		}
        if(where.getAdd_time()!=null){
			whereWrapper.eq("add_time",where.getAdd_time());
		}
        if(where.getOrder_id()!=null){
			whereWrapper.eq("order_id",where.getOrder_id());
		}
        if(where.getTraded_score()!=null){
			whereWrapper.eq("traded_score",where.getTraded_score());
		}
        return whereWrapper;
    }

    /**
     * 会员积分记录新增
     * @param model 会员积分记录实体
     * @return 影响行数
     */
	@Override
    public Integer add(JbrUserScoreList model){
        return jbrUserScoreListMapper.insert(model);
    }

    /**
     * 会员积分记录修改byid
     * @param model 会员积分记录实体
     * @return 影响行数
     */
	@Override
    public Integer update(JbrUserScoreList model) {
        return jbrUserScoreListMapper.updateById(model);
    }

    /**
     * 会员积分记录修改by条件
     * @param model 会员积分记录实体
     * @param where 会员积分记录条件
     * @return 影响行数
     */
	@Override
    public Integer update(JbrUserScoreList model, Wrapper<JbrUserScoreList> where) {
        return jbrUserScoreListMapper.update(model, where);
    }

    /**
     * 会员积分记录修改by条件-自动封装Wrapper
     * @param model 会员积分记录实体
     * @return 影响行数
     */
	@Override
    public Integer update(JbrUserScoreList model, JbrUserScoreList where) {
        Wrapper<JbrUserScoreList> wrapper = InitWrapper(where);
        return update(model, wrapper);
    }

    /**
     * 会员积分记录修改bySQL *version_id = newVersion where version_id = oldVersion
     * @param fields 修改的数据 col1=xx,col2=yy
     * @param where 参数化条件 col1=#{col1}
     * @param params 条件参数 col1=xx
     * @return 影响行数
     */
	@Override
    public Integer update(Map<String, Object> fields, String where, Map<String, Object> params) {
        return dbHelper.update("jbr_user_score_list", fields, where, params);
    }

    /**
     * 会员积分记录删除byid
     * @param id 会员积分记录主键
     * @return 影响行数
     */
	@Override
    public Integer del(int id) {
        return jbrUserScoreListMapper.deleteById(id);
    }

    /**
     * 会员积分记录删除by条件
     * @param where 会员积分记录条件
     * @return 影响行数
     */
	@Override
    public Integer del(Wrapper<JbrUserScoreList> where) {
        return jbrUserScoreListMapper.delete(where);
    }

    /**
     * 会员积分记录删除by条件-自动封装Wrapper
     * @param where 会员积分记录条件
     * @return 影响行数
     */
    @Override
    public Integer del(JbrUserScoreList where) { 
        Wrapper<JbrUserScoreList> wrapper = InitWrapper(where);
        return del(wrapper);
    }

    /**
     * 会员积分记录批量删除byid
     * @param ids 会员积分记录主键集合
     * @return 影响行数
     */
	@Override
    public Integer del(List<Integer> ids){
        return jbrUserScoreListMapper.deleteBatchIds(ids);
    }

    /**
     * 会员积分记录批量删除bymap条件
     * @param map 会员积分记录map条件
     * @return 影响行数
     */
	@Override
    public Integer del(Map<String,Object> map){
        return jbrUserScoreListMapper.deleteByMap(map);
    }

    /**
     * 会员积分记录详情byid
     * @param id 会员积分记录主键
     * @return 会员积分记录详情
     */
	@Override
    public JbrUserScoreListView info(int id){
        return jbrUserScoreListMapperView.selectById(id);
    }

    /**
     * 会员积分记录详情by条件
     * @param where 会员积分记录条件
     * @return 会员积分记录详情
     */
	@Override
    public JbrUserScoreListView info(Wrapper<JbrUserScoreListView> where){
        return jbrUserScoreListMapperView.selectOne(where);
    }

    /**
     * 会员积分记录详情by条件-自动封装Wrapper
     * @param where 会员积分记录条件
     * @return 会员积分记录详情
     */
	@Override
    public JbrUserScoreListView info(JbrUserScoreListView where) {
        Wrapper<JbrUserScoreListView> wrapper = InitWrapperView(where);
        return info(wrapper);
    }

    /**
     * 会员积分记录详情bySQL
     * @param columns  列名col1,col2,col3^
     * @param where 条件 col1=#{col1}
     * @param params col1:xx
     * @param mappings col1->col1
     * @return
     */
	@Override
    public JbrUserScoreList info(String columns, String where, Map<String, Object> params, ResultMapping mappings) {
        return dbHelper.selectOne(columns, "jbr_user_score_list", where, params, JbrUserScoreList.class, mappings);
    }

    /**
     * 会员积分记录批量查询byid
     * @param ids 会员积分记录主键集合
     * @return 会员积分记录列表
     */
	@Override
    public List<JbrUserScoreListView> select(List<Integer> ids){
        return jbrUserScoreListMapperView.selectBatchIds(ids);
    }

    /**
     * 会员积分记录批量查询by条件
     * @param where 会员积分记录条件
     * @return 会员积分记录列表
     */
	@Override
    public List<JbrUserScoreListView> select(Wrapper<JbrUserScoreListView> where){
        return jbrUserScoreListMapperView.selectList(where);
    }

    /**
     * 会员积分记录批量查询by条件-自动封装Wrapper
     * @param where 会员积分记录条件
     * @return 会员积分记录列表
     */
    @Override
    public List<JbrUserScoreListView> select(JbrUserScoreListView where) {
        Wrapper<JbrUserScoreListView> wrapper = InitWrapperView(where);		
        return select(wrapper);
    }

    /**
     * 会员积分记录批量查询bymap条件
     * @param map 会员积分记录map条件
     * @return 会员积分记录列表
     */
	@Override
    public List<JbrUserScoreListView> select(Map<String,Object> map){
        return jbrUserScoreListMapperView.selectByMap(map);
    }

    /**
     * 会员积分记录批量查询b条件分页
     * @param page 分页条件
     * @param where 查询条件
     * @return
     */
	@Override
    public IPage<JbrUserScoreListView> select(IPage<JbrUserScoreListView> page, Wrapper<JbrUserScoreListView> where){
        return jbrUserScoreListMapperView.selectPage(page, where);
    }

    /**
     * 会员积分记录批量查询b条件分页
     * @param page 分页条件
     * @param where 查询条件
     * @return
     */
    @Override
    public IPage<JbrUserScoreListView> select(IPage<JbrUserScoreListView> page, JbrUserScoreListView where) {
		Wrapper<JbrUserScoreListView> wrapper = InitWrapperView(where);		
        return select(page, wrapper);
    }

    /**
     * 会员积分记录查询记录数
     * @param where 查询条件
     * @return
     */
	@Override
    public Integer selectCount(Wrapper<JbrUserScoreListView> where){
        return jbrUserScoreListMapperView.selectCount(where);
    }

    /**
     * 会员积分记录查询记录数
     * @param where 查询条件
     * @return
     */
	@Override
    public Integer selectCount(JbrUserScoreListView where){
		Wrapper<JbrUserScoreListView> wrapper = InitWrapperView(where);
        return selectCount(wrapper);
    }

    /**
     * 会员积分记录批量查询bySQL条件分页
     * @param columns 列col1,col2,col3……
     * @param where 条件col1=#{col1} and col2=#{col2}
     * @param orderBy 排序字段
     * @param params 参数化 col1=xx
     * @param pageNumber 分页页码
     * @param pageSize 每页行数
     * @param mappings 查询列和实体映射
     * @return 分页之后的数据含总行数
     */
	@Override
    public DataPage<JbrUserScoreListView> select(String columns, String where, String orderBy, Map<String, Object> params, int pageNumber, int pageSize, ResultMapping mappings){
        return dbHelper.select(columns, "jbr_user_score_list", where, orderBy, params, pageNumber, pageSize, JbrUserScoreListView.class,mappings);
    }

    /**
     * 会员积分记录批量查询bySQL条件
     * @param columns 列col1,col2,col3……
     * @param where 条件col1=#{col1} and col2=#{col2}
     * @param params 参数化 col1=xx
     * @param mappings 查询列和实体映射
     * @return 栏目扩展列表
     */
	@Override
    public List<JbrUserScoreListView> select(String columns, String where, Map<String, Object> params, ResultMapping mappings){
        return dbHelper.select(columns,"jbr_user_score_list",where,params,JbrUserScoreListView.class,mappings);
    }
}